## Introduction to SYS/BIOS

- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## Need for an Operating System



- Simple system: single I-P-O is easy to manage
- As system complexity increases (multiple threads):
  - ➤ Can they all meet real time ?
    ➤ Synchronization of events?
  - Priorities of threads/algos ?
- Data sharing/passing ?
- 2 options: "home-grown" or use existing (SYS/BIOS) (either option requires overhead)
- If you choose an existing O/S, what should you consider?
  - > Is it modular?
  - ➤ Is it easy to use ?
  - > How much does it cost?

- > Is it reliable?
- Data sharing/passing ?
- > What code overhead exists?

### **SYS/BIOS Overview**



#### SYS/BIOS is a scalable, real-time kernel used in 1000s of systems today:

- Pre-emptive <u>Scheduler</u> to design system to meet real-time (including sync/priorities)
- Modular pre-defined interface for inter-thread communications
- Reliable 1000s of applications have used it for more than 10 years
- Footprint deterministic, small code size, can choose which modules you desire
- · Cost free of charge

### **SYS/BIOS Modules & Services**



### **BIOS Configuration**

- Memory Mgmt
  - Cache & Heaps
- Realtime Analysis
  - Logs, Loads, Execution Graph
- Scheduling
  - All thread types
- Synchronization
  - Semaphores, Events, Gates

How do you interact with the SYS/BIOS services?

### **SYS/BIOS Environment**

```
User Code
                                                 SYS/BIOS Library
#include <log.h>
                 #include <swi.h>
                                           Hwi
                                                   Swi
                                                           Task
                                                                   Idle
func1
                 func2
                                           Stream Mailbox
                                                             Semaphore
                                   API
                   Swi_post(...);
                                           Queue Clock Log HeapMem
 Log_info1(...);
                                           HeapBuf
                                                         HeapMultiBuf
```

- SYS/BIOS is a <u>library</u> that contains modules with a particular interface and data structures
- Application Program Interfaces (API) define the interactions (methods) with a module and data structures (objects)
- Objects are structures that define the state of a component
  - Pointers to objects are called handles
  - Object based programming offers:
    - Better encapsulation and abstraction
    - Multiple instance ability



## **Definitions / Vocabulary**

In this workshop, we'll be using these terms often:

#### **Real-time System**

Where processing must keep up with the rate of I/O

#### **Function**

Sequence of program instructions that produce a given result

### **Thread**



Function that executes within a specific context (regs, stack, PRIORITY)

#### **API**

Application Programming Interface – "methods" for interacting with library routines and data objects

### RTOS vs GP/OS

|                       | GP/OS (e.g. Linux)        | RTOS (e.g. SYS/BIOS)          |  |  |
|-----------------------|---------------------------|-------------------------------|--|--|
| Scope                 | General                   | Specific                      |  |  |
| Size                  | Large: 5M-50M             | Small: 5K-50K                 |  |  |
| <b>Event response</b> | 1ms to .1ms               | 100 – 10 ns                   |  |  |
| File management       | FAT, etc                  | FatFS                         |  |  |
| Dynamic Memory        | Yes                       | Yes                           |  |  |
| Threads               | Processes, pThreads, Ints | ds, Ints Hwi, Swi, Task, Idle |  |  |
| Scheduler             | Time Slicing              | Preemption                    |  |  |
| <b>Host Processor</b> | ARM, x86, Power PC        | ARM, MSP430, M3, C28x, DSP    |  |  |

- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## **SYS/BIOS Thread Types**

#### Hwi

**Hardware Interrupts** 

- Implements 'urgent' part of real-time event
- ◆ Hardware interrupt triggers ISRs to run
- Priorities set by hardware

#### Swi

**Software Interrupts** 

- Performs HWI '<u>follow-up</u>' activity
- 'posted' by software
- Periodic (Clock) functions are prioritized as SWIs
- Up to 32 priority levels (16 on C28x)

#### **Task**

**Tasks** 

- Runs programs concurrently under separate contexts
- Usually enabled to run by posting a '<u>semaphore</u>' (a task signaling mechanism)
- Up to 32 priority levels (16 on C28x)

#### Idle

**Background** 

- Multiple Idle functions
- Runs as an infinite loop (like traditional while(1) loop)
- Single priority level

## Hwi's Signaling Swi/Task



#### Hwi

- Fast response to interrupts
- Minimal context switching
- High priority only
- Can post Swi
- Use for urgent code only then post follow up activity

#### Swi

- Latency in response time
- Context switch performed
- Selectable priority levels
- Can post another Swi
- Execution managed by scheduler

### Swi's and Tasks



- Similar to hardware interrupt, but triggered when posted
- All Swi's share system software stack with Hwi's



- Unblocking triggers execution (also could be mailbox, events, etc.)
- Each <u>Task</u> has its own stack, which allows them to pause (i.e. block)
- Topology: prologue, loop, epilogue...

- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## **Thread (Object) Creation in BIOS**

#### Users can create threads (BIOS resources or "objects"):

- Statically (via the GUI or .cfg script)
- Dynamically (via C code) more details in the "dynamic" chapter
- BIOS doesn't care but you might...
   Dynamic (C Code)



- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## **System Timeline**

| Hard            | ware           | Software |                           |                     |                               |                       |
|-----------------|----------------|----------|---------------------------|---------------------|-------------------------------|-----------------------|
| Reset<br>H/W    | BOOT<br>MODE   |          | Provided by TI            | main.c              |                               | Provided by TI        |
| Device<br>Reset | Boot<br>Loader |          | BIOS_init()<br>(_c_int00) | System<br>Init Code | BIOS_start() (Provided by TI) | SYS/BIOS<br>Scheduler |
|                 |                |          |                           |                     |                               |                       |

- ◆ RESET Device is reset, then jumps to bootloader or code entry point (c int00)
- BOOT MODE runs bootloader (if applicable)
- ◆ BIOS\_init() configs static BIOS objects, jumps to c\_int00 to init Stack Pointer (SP), globals/statics, then calls main()
- main()
  - User initialization
  - Must execute BIOS start() to enable BIOS Scheduler & INTs

- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## **Built-in Real-Time Analysis Tools**

- Gather data on target (30-40 CPU cycles)
- Format data on host (1000s of host PC cycles)
- Data gathering does NOT stop target CPU
- Halt CPU to see results (stop-time debug)



### RunTime Obj View (ROV)

- Halt to see results
- Displays stats about all threads in system



#### **CPU/Thread Load Graph**

Analyze time NOT spent in Idle

**CI Training** 

## **Built-in Real-Time Analysis Tools**

#### Logs

- Send DBG Msgs to PC
- Data displayed during stop-time
- Deterministic, low CPU cycle count
- WAY more efficient than traditional printf()



#### Log\_info1("TOGGLED LED [%u] times", count);

#### **Execution Graph**

- View system events down to the CPU cycle...
- Calculate benchmarks



- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## Building a **NEW** SYS/BIOS Project

Create CCS Project (as normal), then click:



Select a SYS/BIOS Example:



# What's in the project created by "Typical"?

- Paths to SYS/BIOS tools
- .CFG file (app.cfg)
   that contains "typical"
   configuration for static
   objects (e.g. Swi, Task...)
- Source files (main.c) that contains appropriate #includes of header files

## **SYS/BIOS Project Settings**

Select versions for XDC, IPC, SYS/BIOS, xDAIS

TEXAS INSTRUMENTS

Select "Platform" file (similar to the .tcf seed file for memory)



**CI Training** 

- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



### Static BIOS Configuration

- Users interact with the CFG file via the GUI XGCONF:
  - XGCONF shows "Available Products" Right-click and "Use Mod"



## Static Config – .CFG Files

Users interact with the CFG file via the GUI – XGCONF:



## .CFG Files (XDC script)

- All changes made to the GUI are reflected with java script in the .CFG file
- Click on a module on the right, see the corresponding script in app.cfg

```
app.cfg \( \text{2} \)

11

12 var BIOS = xdc.useModule('ti.sysbios.BIOS');

13 var Clock = xdc.useModule('ti.sysbios.knl.Clock');

14 var Swi = xdc.useModule('ti.sysbios.knl.Swi');

15 var Task = xdc.useModule('ti.sysbios.knl.Task');

16 var Semaphore = xdc.useModule('ti.sysbios.knl.Semaphore');

17 var Hwi = xdc.useModule('ti.sysbios.hal.Hwi');

18 var Idle = xdc.useModule('ti.sysbios.knl.Idle');

19 var Timestamp = xdc.useModule('xdc.runtime.Timestamp');

20
```



TEXAS INSTRUMENTS



## **Configuration Build Flow (CFG)**

- <u>SYS/BIOS</u> user configures system with <u>CFG file</u>
- The rest is "under the hood"



- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - For More Info.....
- BIOS Threads



## Platform (Memory Config)

#### **Memory Config**

- Create Internal Memory Segments (e.g. IRAM)
- Configure cache
- Define External Memory Segments

#### **Section Placement**

 Can link code, data and stack to any defined mem segment

#### **Custom Platform**

 Use "Import" button to copy "seed" platform and then customize



- Intro to SYS/BIOS
  - Overview
  - Threads and Scheduling
  - Creating a BIOS Thread
  - System Timeline
  - Real-Time Analysis Tools
  - Create A New Project
  - BIOS Configuration (.CFG)
  - Platforms
  - ◆ For More Info.....
- BIOS Threads



## For More Information (1)

♦ SYS/BIOS Product Page (www.ti.com/sysbios).



## For More Information (2)

#### CCS Help Contents



- User Guides
- API Reference (knl)



#### **Download Latest Tools**

Download Target Content

http://software-dl.ti.com/dsps/dsps\_public\_sw/sdo\_sb/targetcontent/



- DSP/BIOS
- SYS/BIOS
- Utilities
- SysLink
- DSP Link
- IPC
- Etc.

- Intro to SYS/BIOS
- BIOS Threads
  - Hardware Interrupts (HWI)
  - Software Interrupts (SWI)
  - Tasks (TSK)
  - Semaphores (SEM)



## **Hwi Scheduling**

Hard R/T

### Hwi (hi)

**Hardware Interrupts** 

- Hwi priorities set by hardware
- Fixed number, preemption optional

Swi

**Software Interrupts** 

◆ Up to 32 priority levels (16 on C28x)

Any number possible, all preemptive

**Task** 

**Tasks** 

**♦** Up to 32 priority levels (16 on C28x)

**♦** Any number possible, all preemptive

Soft R/T Idle (Io)

**Background** 

Continuous loop

Non-realtime in nature

- ◆ Idle events run in sequence when no Hwis are posted
- ◆ Hwi is ISR with automatic vector table generation + context save/restore
- Any Hwi preempts Idle, Hwi may preempt other Hwi if desired

Foreground / Background Scheduling



- ◆ Idle events run in sequence when no Hwis are posted
- Hwi is ISR with automatic vector table generation + context save/restore
- Any Hwi preempts Idle, Hwi may preempt other Hwi if desired

### **CPU Interrupts from Peripheral (Ex: McASP)**



- Peripheral (e.g. McASP on C6748) causes an interrupt to the CPU to indicate "service required".
- ◆ This "event" will have an ID (datasheet) and can be tied to a specific CPU interrupt (target specific)

How do we configure SYS/BIOS to respond to this interrupt and call the appropriate ISR?

# Configuring an <u>Hwi</u> – Statically via GUI

**Example:** Tie McASP0\_INT to the CPU's HWI<sub>5</sub>

1 Use Hwi module (Available Products), insert new Hwi (Outline View)



Remember, BIOS objects can be created via the GUI, script code or C code (dynamic)

2 Configure Hwi – Event ID, CPU Int #, ISR vector:



♦ Texas Instruments

#### **Hardware Event IDs**

So, how do you know the names of the interrupt events and their corresponding event numbers?

Look it up (in the datasheet), of course...

Ref: TMS320C6748 datasheet (exerpt):

| 59 | GPIO_B5INT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    | GPIO Bank 5 Interrupt            |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------|
| 60 | DDR2_MEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ERR                | DDR2 Memory Error Interrupt      |
| 61 | MCASP0_I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | NT                 | McASP0 Combined RX/TX Interrupts |
| 62 | Account to the same of the sam |                    | GPIO Bank 6 Interrupt            |
| 63 | ▼ Interrupt Sche                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | duling Options     | RTC Combined                     |
|    | Interrupts to mask                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MaskingOption_SELF |                                  |
|    | Priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5                  |                                  |
|    | Event Id                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 61                 |                                  |
|    | Enabled at startup                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                    |                                  |

This example is target-specific for the C6748 DSP.
 Simply refer to your target's datasheet for similar info.

What happens in the ISR?

# **Example ISR (McASP)**

#### **Example ISR for MCASP0\_INT interrupt**



#### isrAudio:

```
pInBuf[blkCnt] = MCASP1->RCV; // READ audio sample from McASP
MCASP->XMT = pOutBuf[blkCnt]
                               // WRITE audio sample to McASP
blkCnt+=1;
                               // increment blk counter
if( blkCnt >= BUFFSIZE )
  memcpy(pOut, pIn, Len);  // Copy pIn to pOut (Algo)
  blkCnt = 0;
                               // reset blkCnt for new buf's
  pingPong ^= 1;
                               // PING/PONG buffer boolean
```

Can one interrupt preempt another?

**Enabling Preemption of Hwi** 



- Default mask is "SELF" which means all other Hwi's can pre-empt except for itself
- Can choose other masking options as required:

**ALL:** Best choice if ISR is short & fast

NONE: Dangerous – make sure ISR code is re-entrant

**BITMASK:** Allows custom mask

LOWER: Masks any interrupt(s) with lower priority (ARM)

### **SYS/BIOS Hwi APIs**

#### Other useful Hwi APIs:

```
Set enable bit = 0
Hwi disableInterrupt()
                               Set enable bit = 1
Hwi enableInterrupt()
                               Clear INT flag bit = 0
Hwi clearInterrupt()
                 New in SYS/BIOS
                               Post INT # (in code)
Hwi post()
                               Global INTs disable
Hwi disable()
                               Global INTs enable
Hwi enable()
                               Global INTs restore
Hwi restore()
```

Let's move on to SWIs...

#### **Outline**

- Intro to SYS/BIOS
- BIOS Threads
  - Hardware Interrupts (HWI)
  - Software Interrupts (SWI)
  - Tasks (TSK)
  - Semaphores (SEM)



# Swi Scheduling

Hard R/T Hwi (hi)
Hardware Interrupts

- Hwi priorities set by hardware
- Fixed number, preemption optional

#### **Swi**

**Software Interrupts** 

- ◆ Up to 32 priority levels (16 on C28x)
- **♦** Any number possible, all preemptive

**Task** 

**Tasks** 

- **♦** Up to 32 priority levels (16 on C28x)
- **♦** Any number possible, all preemptive

Soft R/T Idle (Io)
Background

- Continuous loop
- **♦** Non-realtime in nature

- ◆ SYS/BIOS provides for Hwi and Swi management
- ◆ SYS/BIOS allows the Hwi to post a Swi to the ready queue

# Hardware and Software Interrupt System

#### **Execution flow for flexible real-time systems:**



#### Hwi

- Fast response to INTs
- Min context switching
- High priority for CPU
- Limited # of Hwi possible

#### isrAudio:

```
*buf++ = *XBUF;
cnt++;
if (cnt >= BLKSZ) {
    Swi_post(swiFir);
    count = 0;
    pingPong ^= 1;
}
```

#### Swi

- Latency in response time
- Context switch
- Selectable priority levels
- Scheduler manages execution

- ◆ SYS/BIOS provides for Hwi and Swi management
- ◆ SYS/BIOS allows the Hwi to post a Swi to the ready queue

Scheduling SWIs...

# **Scheduling Rules**



- Swi\_post(mySwi): Unconditionally post a software interrupt (in the ready state)
- If a higher priority thread becomes ready, the running thread is preempted
- Swi priorities from 1 to 32 (C28x has 16)
- Automatic context switch (uses system stack)

What if the SWIs are at the same priority?

# **Scheduling Rules**



- Processes of same priority are scheduled first-in first-out (FIFO)
- Having threads at the SAME priority offers certain advantages –
   such as resource sharing (without conflicts)

How do you configure a SWI?

# Configuring a <u>Swi</u> – Statically via GUI

**Example:** Tie isrAudio() fxn to Swi, use priority 1

1 Use Swi module (Available Products), insert new Hwi (Outline View)



Remember, BIOS objects can be created via the GUI, script code or C code (dynamic)

**2** Configure Swi – Object name, function, priority:



TEXAS INSTRUMENTS

Let's move on to Tasks...

CI Training

### **SYS/BIOS Swi APIs**

#### Other useful Swi APIs:

| Swi_inc()     | Post, increment count        |  |
|---------------|------------------------------|--|
| Swi_dec()     | Decrement count, post if 0   |  |
| Swi_or()      | Post, OR bit (signature)     |  |
| Swi_andn()    | ANDn bit, post if all posted |  |
| Swi_getPri()  | Get any Swi Priority         |  |
| Swi_enable    | Global Swi enable            |  |
| Swi_disable() | Global Swi disable           |  |
| Swi_restore() | Global Swi restore           |  |

Let's move on to Tasks...

### **Outline**

- Intro to SYS/BIOS
- BIOS Threads
  - Hardware Interrupts (HWI)
  - Software Interrupts (SWI)
  - Tasks (TSK)
  - Semaphores (SEM)



# Task Scheduling

Hard R/T Hwi (hi)
Hardware Interrupts

Hwi priorities set by hardware

Fixed number, preemption optional

Swi

**Software Interrupts** 

◆ Up to 32 priority levels (16 on C28x)

Any number possible, all preemptive

**Task** 

**Tasks** 

**♦** Up to 32 priority levels (16 on C28x)

**♦** Any number possible, all preemptive

Soft R/T Idle (Io)

**Background** 

Continuous loop

Non-realtime in nature

- All Tasks are preempted by all Swi and Hwi
- All Swi are preempted by all Hwi
- Preemption amongst Hwi is determined by user
- In absence of Hwi, Swi, and Task, Idle functions run in loop

# Task Code Topology – Pending



```
Void taskFunction(...)
                                   Initialization (runs once only)
/* Prolog */
   while ('condition'){
                                Processing loop – (optional: cond)
        Semaphore_pend()
                                  Wait for resources to be available
                                Perform desired algo work...
        /* Process */ <
/* Epilog */
                                   Shutdown (runs once - at most)
```

- Task can encompass three phases of activity
- Semaphore can be used to signal resource availability to Task
- Semaphore\_pend() blocks Task until semaphore (flag) is posted

Let's compare/contrast Swi & Task...

### Swi vs. Task

Swi Task

```
_post→ void mySwi () {

// set local env

*** RUN ***
```

- "Ready" when POSTED
- Initial state NOT preserved must set each time Swi is run
- CanNOT block (runs to completion)
- Context switch speed (~140c)
- All Swi's share system stack w/Hwi
- Use: as follow-up to Hwi and/or when memory size is an absolute premium

```
create >void myTask () {
    // Prologue (set Task env)
    while (cond) {
        Semaphore_pend();
        *** RUN ***
    }
    // Epilogue (free env)
}
```

- "Ready" when <u>CREATED</u> (BIOS\_start or dynamic)
- P-L-E structure handy for resource creation (P) and deletion (E), initial state preserved
- Can block/suspend on semaphore (flag)
- Context switch speed (~160c)
- Uses its OWN stack to store context
- Use: Full-featured sys, CPU w/more speed/mem

### Configuring a <u>Task</u> – Statically via the GUI

Example: Create firProcessTask, tie to FIR process(), priority 2

1 Use Task module (Available Products), insert new Task (Outline View)



Remember, BIOS objects can be created via the GUI, script code or C code (dynamic)

**2** Configure Task – Object name, function, priority, stack size:



### **Outline**

- Intro to SYS/BIOS
- BIOS Threads
  - Hardware Interrupts (HWI)
  - Software Interrupts (SWI)
  - Tasks (TSK)
  - Semaphores (SEM)



## **Semaphore Pend**



TEXAS INSTRUMENTS

How does \_post work?

**CI Training** 

## **Semaphore Post**



How do you configure a Semaphore?

### Configuring a <u>Semaphore</u> – Statically via GUI

**Example:** Create mcaspReady, counting

1 Use Semaphore (Available Products), insert new Semaphore (Outline View)



**2** Configure Semaphore – Object name, initial count, type:



TEXAS INSTRUMENTS

**CI Training** 

# SYS/BIOS Semaphore/Task APIs Other useful Semaphore APIs:

Semaphore\_getCount()

Get semaphore count

#### Other useful Task APIs:

| Task_sleep()      | Sleep for N system ticks |  |
|-------------------|--------------------------|--|
| Task_yield()      | Yield to same pri Task   |  |
| Task_setPri()     | Set Task priority        |  |
| Task_getPri()     | Get Task priority        |  |
| Task_get/setEnv() | Get/set Task Env         |  |
| Task_enable()     | Enable Task Mgr          |  |
| Task_disable()    | Disable Task Mgr         |  |
| Task_restore()    | Restore Task Mgr         |  |

### **Questions?**